package com.coupon.admin.entity;

import com.baomidou.mybatisplus.annotation.*;
import lombok.Data;
import lombok.EqualsAndHashCode;

import java.time.LocalDateTime;

/**
 * 用户实体类
 */
@Data
@EqualsAndHashCode(callSuper = false)
@TableName("user")
public class User {
    
    @TableId(value = "id", type = IdType.AUTO)
    private Long id;
    
    /**
     * 用户名
     */
    private String username;
    
    /**
     * 手机号
     */
    private String phone;
    
    /**
     * 邮箱
     */
    private String email;
    
    /**
     * 昵称
     */
    private String nickname;
    
    /**
     * 头像
     */
    private String avatar;
    
    /**
     * 性别：MALE(男), FEMALE(女), UNKNOWN(未知)
     */
    private String gender;
    
    /**
     * 生日
     */
    private LocalDateTime birthday;
    
    /**
     * 会员等级
     */
    private String memberLevel;
    
    /**
     * 积分
     */
    private Integer points;
    
    /**
     * 用户标签（JSON格式）
     */
    private String tags;
    
    /**
     * 用户画像（JSON格式）
     */
    private String profile;
    
    /**
     * 最后登录时间
     */
    private LocalDateTime lastLoginTime;
    
    /**
     * 最后消费时间
     */
    private LocalDateTime lastConsumeTime;
    
    /**
     * 消费频次（月）
     */
    private Integer consumeFrequency;
    
    /**
     * 平均客单价
     */
    private Double avgOrderValue;
    
    /**
     * 偏好品类（JSON格式）
     */
    private String preferredCategories;
    
    /**
     * 价格敏感度：HIGH(高), MEDIUM(中), LOW(低)
     */
    private String priceSensitivity;
    
    /**
     * 状态：ACTIVE(正常), INACTIVE(禁用), FROZEN(冻结)
     */
    private String status;
    
    /**
     * 创建时间
     */
    @TableField(fill = FieldFill.INSERT)
    private LocalDateTime createTime;
    
    /**
     * 更新时间
     */
    @TableField(fill = FieldFill.INSERT_UPDATE)
    private LocalDateTime updateTime;
    
    /**
     * 逻辑删除标记
     */
    @TableLogic
    private Integer deleted;
}
